i2crepeater 2.2.0
Loading...
Searching...
No Matches
i2crepeater


I2C Repeater Click

I2C Repeater Click demo application is developed using the NECTO Studio, ensuring compatibility with mikroSDK's open-source libraries and tools. Designed for plug-and-play implementation and testing, the demo is fully compatible with all development, starter, and mikromedia boards featuring a mikroBUS™ socket.


Click Library

  • Author : Stefan Filipovic
  • Date : Jul 2025.
  • Type : I2C type

Software Support

Example Description

This example demonstrates the communication through the I2C Repeater Click board. It initializes the device, sets the slave I2C address of an external I2C sensor (e.g. 6DOF IMU 11 Click), and reads its device ID register, verifying if the expected ID is returned.

Example Libraries

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.I2CRepeater

Example Key Functions

Application Init

Initializes the logger and the I2C Repeater Click, then enables the device.

void application_init ( void )
{
log_cfg_t log_cfg;
i2crepeater_cfg_t i2crepeater_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
i2crepeater_cfg_setup( &i2crepeater_cfg );
I2CREPEATER_MAP_MIKROBUS( i2crepeater_cfg, MIKROBUS_1 );
if ( I2C_MASTER_ERROR == i2crepeater_init( &i2crepeater, &i2crepeater_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
i2crepeater_enable_device ( &i2crepeater );
log_info( &logger, " Application Task " );
}
#define I2CREPEATER_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition i2crepeater.h:92
void application_init(void)
Definition main.c:38

Application Task

Sets the I2C address of a connected I2C sensor and reads its device ID, then logs whether the returned ID matches the expected value.

void application_task ( void )
{
uint8_t device_id = 0;
{
if ( I2CREPEATER_OK == i2crepeater_i2c_read_reg ( &i2crepeater, DEVICE_REG_ID, &device_id, 1 ) )
{
log_printf( &logger, " %s - Device ID: 0x%.2X - %s\r\n\n",
( char * ) DEVICE_NAME, ( uint16_t ) device_id,
( char * ) ( ( DEVICE_ID == device_id ) ? "OK" : "NOK" ) );
}
Delay_ms ( 1000 );
}
}
@ I2CREPEATER_OK
Definition i2crepeater.h:139
#define DEVICE_ID
Definition main.c:33
void application_task(void)
Definition main.c:70
#define DEVICE_NAME
Definition main.c:30
#define DEVICE_SLAVE_ADDRESS
Definition main.c:31
#define DEVICE_REG_ID
Definition main.c:32

Note

Make sure to provide the power supply to VCCB side for the connected I2C sensor.

Application Output

This Click board can be interfaced and monitored in two ways:

  • Application Output - Use the "Application Output" window in Debug mode for real-time data monitoring. Set it up properly by following this tutorial.
  • UART Terminal - Monitor data via the UART Terminal using a USB to UART converter. For detailed instructions, check out this tutorial.

Additional Notes and Information

The complete application code and a ready-to-use project are available through the NECTO Studio Package Manager for direct installation in the NECTO Studio. The application code can also be found on the MIKROE GitHub account.